문장 집합 연산자¶
UNION, DIFFERENCE, INTERSECTION¶
피연산자로 지정된 하나 이상의 질의문의 결과에 대해 합집합(UNION), 차집합(DIFFERENCE), 교집합(INTERSECTION)을 구하기 위하여 문장 집합 연산자(Statement Set Operator)를 이용한다. 단, 두 질의문의 대상 테이블에서 조회하고자 하는 데이터 타입이 동일하거나, 묵시적으로 변환 가능해야 한다. 다음은 CUBRID가 지원하는 문장 집합 연산자와 예제를 나타낸 표이다.
CUBRID가 지원하는 문장 집합 연산자
문장 집합 연산자 | 설명 | 비고 |
---|---|---|
UNION | 합집합 중복을 허용하지 않음 | UNION ALL 이면 중복된 값을 포함한 모든 결과 인스턴스 출력 |
DIFFERENCE | 차집합 중복을 허용하지 않음 | EXCEPT 연산자와 동일 DIFFERENCE ALL 이면 중복된 값을 포함한 모든 결과 인스턴스 출력 |
INTERSECTION | 교집합 중복을 허용하지 않음 | INTERSECT 연산자와 동일 INTERSECTION ALL 이면 중복된 값을 포함한 모든 결과 인스턴스 출력 |
구문
query_term statement_set_operator [qualifier] query_term
[{statement_set_operator [qualifier] query_term}];
query_term :
• query_specification
• subquery
qualifier :
• DISTINCT, DISTINCTROW 또는 UNIQUE(결과로 반환되는 인스턴스가 서로 다르다는 것을 보장)
• ALL (모든 인스턴스가 반환, 중복 허용)
statement_set_operator :
• UNION (합집합)
• DIFFERENCE (차집합)
• INTERSECT | INTERSECTION (교집합)
예제
CREATE TABLE nojoin_tbl_1 (ID INT, Name VARCHAR(32));
INSERT INTO nojoin_tbl_1 VALUES (1,'Kim');
INSERT INTO nojoin_tbl_1 VALUES (2,'Moy');
INSERT INTO nojoin_tbl_1 VALUES (3,'Jonas');
INSERT INTO nojoin_tbl_1 VALUES (4,'Smith');
INSERT INTO nojoin_tbl_1 VALUES (5,'Kim');
INSERT INTO nojoin_tbl_1 VALUES (6,'Smith');
INSERT INTO nojoin_tbl_1 VALUES (7,'Brown');
CREATE TABLE nojoin_tbl_2 (id INT, Name VARCHAR(32));
INSERT INTO nojoin_tbl_2 VALUES (5,'Kim');
INSERT INTO nojoin_tbl_2 VALUES (6,'Smith');
INSERT INTO nojoin_tbl_2 VALUES (7,'Brown');
INSERT INTO nojoin_tbl_2 VALUES (8,'Lin');
INSERT INTO nojoin_tbl_2 VALUES (9,'Edwin');
INSERT INTO nojoin_tbl_2 VALUES (10,'Edwin');
--Using UNION to get only distinct rows
SELECT id, name FROM nojoin_tbl_1
UNION
SELECT id, name FROM nojoin_tbl_2;
id name
===================================
1 'Kim'
2 'Moy'
3 'Jonas'
4 'Smith'
5 'Kim'
6 'Smith'
7 'Brown'
8 'Lin'
9 'Edwin'
10 'Edwin'
--Using UNION ALL not eliminating duplicate selected rows
SELECT id, name FROM nojoin_tbl_1
UNION ALL
SELECT id, name FROM nojoin_tbl_2;
id name
===================================
1 'Kim'
2 'Moy'
3 'Jonas'
4 'Smith'
5 'Kim'
6 'Smith'
7 'Brown'
5 'Kim'
6 'Smith'
7 'Brown'
8 'Lin'
9 'Edwin'
10 'Edwin'
--Using DEFFERENCE to get only rows returned by the first query but not by the second
SELECT id, name FROM nojoin_tbl_1
DIFFERENCE
SELECT id, name FROM nojoin_tbl_2;
id name
===================================
1 'Kim'
2 'Moy'
3 'Jonas'
4 'Smith'
--Using INTERSECTION to get only those rows returned by both queries
SELECT id, name FROM nojoin_tbl_1
INTERSECT
SELECT id, name FROM nojoin_tbl_2;
id name
===================================
5 'Kim'
6 'Smith'
7 'Brown'